package hash;

import org.checkerframework.checker.units.qual.A;

import java.util.*;
import java.util.stream.Collectors;

/**
 * 349. 两个数组的交集
 *
 * @author Api
 * @date 2023/10/11 23:07
 */
public class Code349_TheIntersectionOfTwoArrays {
    // hashset实现
    public int[] intersection(int[] nums1, int[] nums2) {
        if (nums1 == null || nums1.length == 0 || nums2 == null || nums2.length == 0) {
            return new int[0];
        }
        Set<Integer> set1 = Arrays.stream(nums1).boxed().collect(Collectors.toSet());
        Set<Integer> resSet = new HashSet<>();
        //遍历数组2的过程中判断哈希表中是否存在该元素
        for (int i : nums2) {
            if (set1.contains(i)) {
                resSet.add(i);
            }
        }
        int[] value = new int[resSet.size()];
        // 方法1：将Set结果集合转为数组
        return resSet.stream().mapToInt(x -> x).toArray(); // HashSet转数组
        //方法2：另外申请一个数组存放setRes中的元素,最后返回数组
//        int[] arr = new int[resSet.size()];
//        int j = 0;
//        for(int i : resSet){
//            arr[j++] = i;
//        }
//
//        return arr;
    }

    // 使用Hash数组
    public int[] intersection1(int[] nums1, int[] nums2) {
        int[] hash1 = new int[1002];
        int[] hash2 = new int[1002];
        for (int i : nums1) {
            hash1[i]++;
        }
        for (int i : nums2) {
            hash2[i]++;
        }
        List<Integer> resList = new ArrayList<>();
        for (int i = 0; i < 1002; i++) {
            if (hash1[i] > 0 && hash2[i] > 0) {
                resList.add(i);
            }
        }
        int index = 0;
        int[] res = new int[resList.size()];
        for (int i : resList) {
            res[index++] = i;
        }
        return res;
    }
}
